import { fileURLToPath, URL } from 'node:url'

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import vueJsx from '@vitejs/plugin-vue-jsx'
import vueDevTools from 'vite-plugin-vue-devtools'

// https://vite.dev/config/
export default defineConfig({
  plugins: [vue(), vueJsx(), vueDevTools()],
  base: './', // 关键配置：使用相对路径
   css: {
    extract: true // 确保 CSS 被提取为单独文件
  },
  build: {
    outDir: 'dist',
    lib: {
      entry: 'src/components/index.js',
      name: 'CflowEditorLoader',
      fileName: (format) => `cflow-editor-loader.${format}.js`,
    },
    rollupOptions: {
      // 确保外部化 Vue
      external: ['vue'],
      output: {
        assetFileNames: 'index.[ext]', // 强制 CSS 命名为 index.css
        globals: {
          vue: 'Vue',
        },
      },
    },
  },
  resolve: {
    alias: {
      '@': fileURLToPath(new URL('./src', import.meta.url)),
    },
  },
})
